草庐IT

javascript - 没有 http、https、ftp 的 url 的正则表达式

全部标签

ruby - 有没有办法在 Ruby 中 glob 目录但排除某些目录?

我想为后处理头文件分配一个目录。但是我想排除项目中的一些目录。现在默认的方式是...Dir["**/*.h"].each{|header|putsheader}如果每个header条目位于排除的目录中,则手动检查它似乎效率低下。 最佳答案 我知道这已经晚了4年,但是对于可能遇到这个问题的任何其他人,您可以像从Bash通配符中排除一样从Dir中排除:Dir["lib/{[!errors/]**/*,*}.rb"]这将排除任何以“errors”开头的文件夹,您甚至可以省略/并根据需要将其变成某种通配符。

ruby-on-rails - 在没有额外的 sql 查询的情况下过滤 activerecord 关系?

如何在不执行额外查询的情况下过滤AR查询的结果?例如u=User.where(name:"bob",age:[10,20])#1stselectquerytodbu.class#ActiveRecord::Relationtens=u.where(age:10)#2ndselectquerytodb我不希望第二个查询调用数据库,而是过滤在u(第一个查询)中检索到的结果。 最佳答案 ActiveRecord:Relation仅在访问其元素时查询数据库。因此,您拥有的序列根本不会调用数据库,除非您编写类似u.first或tens.fir

ruby - 如何使用最新版本的 Ruby 连接到具有无效证书的 https 服务器

考虑以下代码:require'net/https'uri=URI.parse("https://host/index.html")http=Net::HTTP.new(uri.host,uri.port)http.use_ssl=truehttp.verify_mode=OpenSSL::SSL::VERIFY_NONErequest=Net::HTTP::Get.new(uri.path)response=http.request(request)其中https://host/index.html是服务器上具有无效证书的有效地址。在旧版本的ruby​​(特别是1.8.7-p334和1

ruby - 如何在 Capybara 中获取包含当前路径的完整 URL

我刚开始使用capybara编写测试,但在获取页面的当前URL时遇到了问题。我是这样写的:url=page.current_url+page.current_path它只是返回基本URL。非常感谢您的帮助。 最佳答案 试试这个:url=URI.parse(current_url) 关于ruby-如何在Capybara中获取包含当前路径的完整URL,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/que

ruby-on-rails - 在 Rails 4 中检测用户代理 - 读取 HTTP header

我刚刚从PHP切换到RubyonRails,想知道是否有一种方法可以检测客户端设备/用户代理(读取HTTPheader),以便根据收到的请求为网站的不同版本提供服务。在PHP中我一直在使用MobileDetect这样做。一般的想法是只提供每个特定版本所需的文件。这就是为什么客户端方法不是那么有效。有没有办法用Ruby2.0.0和Rails4.0.0做类似的事情?也许有gem可以处理这样的情况? 最佳答案 检查request方法,在那里你可以获得ActionDispatch::Request您拥有所有请求参数,包括用户代理。reque

ruby - 在没有参数或任务名称的情况下运行 CLI Thor 应用程序

我正在寻找一种方法来创建命令行thor应用程序,该应用程序将运行不带任何参数的默认方法。我摆弄了Thor的default_method选项,但仍然需要我传递一个参数。我找到了一个similarcase有人想运行带有参数但没有任务名称的CLIThor任务。我想运行一个没有任务名称和参数的任务。这样的事情可能吗? 最佳答案 似乎正确的Thor方式是使用default_task:classCommands如果出于某种原因这不是你需要的,你应该能够做类似的事情classCommands 关于ru

ruby - 如何在没有 sudo 的情况下安装 gems

在我所有的gem安装上我必须执行sudo?所以sudogeminstallrails会工作,而只有geminstallrails将不起作用。我该如何补救?我已经安装了rvm-murtaza@murtaza-dev:~$whichrvm/home/murtaza/.rvm/bin/rvmmurtaza@murtaza-dev:~$whichgem/home/murtaza/.rvm/rubies/ruby-1.9.3-p194/bin/gem但是,当我对gem进行任何操作时,我也会收到此警告-murtaza@murtaza-dev:~$gem/home/murtaza/.rvm/rubi

ruby - ruby 1.9 中有没有办法从字符串中删除无效的字节序列?

假设你有一个像"€foo\xA0"这样的字符串,编码为UTF-8,有没有办法从这个字符串中删除无效的字节序列?(所以你得到"€foo")在ruby​​-1.8中,您可以使用Iconv.iconv('UTF-8//IGNORE','UTF-8',"€foo\xA0")但现在已弃用。"€foo\xA0".encode('UTF-8')不执行任何操作,因为它已经是UTF-8。我试过:"€foo\xA0".force_encoding('BINARY').encode('UTF-8',:undef=>:replace,:replace=>'')产生“foo”但这也丢失了有效的多字节字符€

ruby-on-rails - 在 Ruby 中获取 URL 的重定向

根据Facebook图形API,我们可以使用此请求用户个人资料图片(示例):https://graph.facebook.com/1489686594/picture但上一个链接的真实图片URL是:http://profile.ak.fbcdn.net/hprofile-ak-snc4/hs356.snc4/41721_1489686594_527_q.jpg如果您在浏览器中键入第一个链接,它会将您重定向到第二个链接。有没有什么方法可以通过Ruby/Rails只知道第一个URL来获取完整的URL(第二个链接)?(这是thisquestion的重复,但对于Ruby)

ruby - 另一种方法而不是转义正则表达式模式?

通常当我的正则表达式模式看起来像这样时:http://www.microsoft.com/然后我必须像这样逃避它:string.match(/http:\/\/www\.microsoft\.com\//)有没有其他方法而不是像那样转义它?我希望能够像这样使用它http://www.microsoft.com,因为我不想转义所有模式中的所有特殊字符。 最佳答案 Regexp.new(Regexp.quote('http://www.microsoft.com/'))Regexp.quote简单地转义任何具有特殊正则表达式含义的字符;